package com.ws;

import org.junit.Test;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;

/*
一、异常的处理：抓抛模型

过程一：“抛”：程序在正常执行的过程中，一旦出现异常，就会在异常代码处生成一个对应异常类的对象。
            并将此对象抛出。一旦抛出对象以后，其后的代码就不再执行。

       关于异常对象的产生：① 系统自动生成的异常对象
                         ② 手动的生成一个异常对象，并抛出（throw）

过程二：“抓”：可以理解为异常的处理方式：①try-catch-finally  ②throws

二、try-catch-finally的使用
try{
    //可能出现异常的代码
} catch() {

} catch() {

} finally {//一定会执行的代码}

说明
1.finally是可选的
2.使用try将可能出现的异常代码包装起来，在执行过程中，一旦出现异常，就会生成一个异常类的对象，
根据此对象的类型，去catch中进行匹配
3.一旦try中的异常对象匹配到某一个catch时，就进行catch中进行异常的处理。一旦处理完成，就跳出
当前的try-catch结构（在没有写finally的情况）。继续执行其后的代码
4.catch中的异常类型如果没有子父类关系，则谁声明在上，谁声明在下无所谓。
catch中的异常类型如果满足子父类关系，则要求子类一定要声明在父类上面。
5.常见的异常对象处理的方式：① String getMessage()    ② printStackTrance()
6.在try结构中声明的变量，在出了try结构以后，就不能再被调用

体会1：使用try-catch-finally处理编译时异常，使得程序在编译时就不再报错，但是运行时仍可能报错。
相当于我们使用try-catch-finally将一个编译时可能出现的异常延迟到运行时出现。

体会2：开发中，由于运行时异常比较常见，所以我们通常就不针对运行时异常编写 try-catch-finally了。
    针对编译时异常，我们一定要考虑异常的处理
 */
public class ExceptionTest1 {

    @Test
    public void test1() {
        //NumberFormatException
        String str = "123";
        str = "abc";
        int num = 0;
        try {
            num = Integer.parseInt(str);
            System.out.println("hello--1");
        } catch (NumberFormatException e) {
            System.out.println(e.getMessage());
            //e.printStackTrace();
            //System.out.println("出现数值转换异常");
        }
        System.out.println(num);
        System.out.println("hello--2");
    }


    @Test
    public void test2() {
        try {
            File file = new File("hello.txt");
            FileInputStream fis = new FileInputStream(file);

            int data = fis.read();
            while (data != -1) {
                System.out.println(data);
                data = fis.read();
            }

            fis.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
